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Расширенный базисный конечный автомат. 
Часть I. Основные определения 


Б. Ф. Мельников, А. А. Мельникова 


Annomayua—B настоящей статье мы рассматриваем спе- 
циальное расширение класса недетерминированных конеч- 
ных автоматов. Целью этого рассмотрения является: во- 
первых, описание с помощью подобных автоматов различ- 
ных «переборных» (brute-force) алгоритмов, в том числе — 
алгоритмов эквивалентного преобразования автоматов; во- 
вторых — применение описанного расширения в несколь- 
ких минимизационных проблемах, формулируемых для 
обычных недетерминированных конечных автоматов; в- 
третьих, с помощью расширенных автоматов мы можем 
упростить некоторых доказательства, также нужные для 
обычных конечных автоматов. 

В статье мы рассматриваем определение расширенных 
конечных автоматов, приводим примеры, определяем рас- 
ширенный базисный конечный автомат и рассматриваем 
некоторые его свойства. Также мы доказываем, что для рас- 
ширенного базисного автомата все получаемые в построе- 
ниях вспомогательные языки являются регулярными. Всё 
это позволяет упростить само определение расширенного 
базисного автомата. 

Мы также показываем адекватность определения рас- 
ширенного базисного конечного автомата — т.е. доказываем 
утверждение о том, что построенный на основе исходного 
регулярного языка расширенный базисный автомат дей- 
ствительно определяет этот язык. А на одном из примеров 
мы показываем следующий факт: существуют регулярные 
языки, в базисных автоматах которых у некоторых вершин 
нет циклов, соответствующих циклам соответствующих 
вершин других эквивалентных автоматов; именно такие 
циклы имеются в аналогичных вершинах расширенных 
базисных автоматов. 


Ключевые слова—Регулярные языки, недетерминирован- 
ные конечные автоматы, расширение автоматов, алгорит- 
мы эквивалентного преобразования автоматов. 


1. ВВЕДЕНИЕ 


В настоящей статье мы рассматриваем специальное 
расширение класса недетерминированных конечных ав- 
томатов — определяющее, однако, то же самое множество 
регулярных языков. Целью рассмотрения такого расши- 
рения не является описание очередного способа задания 
класса регулярных языков: просто потому, что уже было 
опубликовано множество работ, в которых описывались 
похожие способы его задания. Например, можно было 
бы подробно рассмотреть расширение класса конечных 
автоматов, в котором каждая дуга помечена некоторым 
регулярным выражением — и фактически мы рассматри- 
вали такой способ в {ii}. Таким образом, в отличие OT т.н. 
обобщённых автоматов (generalized automata, PID, мы He 
стремимся описать как можно более широкое обобщение 
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класса «обычных» конечных автоматов, определяющее 
то же самое множество регулярных языков. Более того, 
мы специально накладываем сформулированные далее 
ограничения на регулярные выражения, которыми могут 
быть помечены дуги. В нашем расширении подобные 
дуги (те. помеченные регулярными выражениями) до- 
пускаются только для стартовых и финальных состояний, 
а также для дуг-петель. 

Материал статьи 8] в настоящей статье существенно 
изменён и дополнен. Мы приводим все определения из 
той статьи (ранее на русском языке не публиковавшиеся) 
и, кроме того: 


e рассматриваем примеры — которых в [8] приктиче- 
ски не было; 

• приводим некоторые связанные вспомогательные 
утверждения, опубликованные ранее в статьях, не 
связанных с тематикой расширенных автоматов; 

• несколько упрощаем приведённые ранее доказатель- 
ства; 

• приводим дополнительные рисунки, иллюстрирую- 
щие их; 

• заменяем схемы доказательств на непосредственные 
доказательства; 

• доказываем, что в расширенном базисном автомате 
(как следует из названия, именно ему в первую оче- 
редь посвящена настоящая статья) все получаемые 
в доказательствах вспомогательные языки являются 
регулярными; отметим, что это не следовало из 
материала, приведённого в (Bh; 

• показываем, как на основе приведённого здесь Ma- 
териала упростить задание расширенного базисного 
автомата. 


Мы предполагаем вернуться к заданию регулярных язы- 
ков с помощью расширенных конечных автоматов в 
статье-продолжении — поэтому нам необходима закон- 
ченная терминология, связанная с этими автоматами. 


Как уже было отмечено, мы в наших предыдущих ра- 
ботах рассматривали и другие расширения класса неде- 
терминированных конечных автоматов — причём эти рас- 
ширения иногда определяют «исходный» класс языков 
(регулярные языки!), а иногда — более широкие классы 
языков. По этому поводу, кроме уже процитированных 
статей ih, В] отметим следующие формализмы. 


e Уже упомянутые выше обобщённые автоматы. При 
этом стоит отметить, что в 0] мы привели несколько 


' В этом случае речь идёт как раз об «очередном» («1001-м») способе 
задания всего класса регулярных языков. Именно это мы имели в виду 
выше. 
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возможных «автоматных моделей» В каждая из кото- 
рых описывает обобщённые регулярные выражения 
(1 и мн.др.). 

• Т.н. л-подклассы класса КС-языков, рассматривав- 
шиеся нами в pl; как показано в той статье, один из 
подклассов совпадает с классом регулярных языков. 

e Скобочные автоматы (bracketed automata) — см. [6], 


А из многочисленных «расширяющих» формализмов, 
описанных не авторами настоящей статьи, отметим толь- 
ко один, следующий. 


• См. [8]; по нашему мнению, этот способ задания 
автоматов может много вариантов практического 
применения — однако дальнейшие публикации на эту 
тему нам неизвестны. 


Можно сказать, немного упрощая рассмотрение всех упо- 
мянутых моделей, что в каждой из них дуги автома- 
та помечены, вообще говоря, не элементами множества 
EU {=}. 

Мы уже упомянули выше, что очередной способ зада- 
ния класса регулярных языков не является целью статьи, 
и вообще, не является целью описываемого нами обоб- 
щения конечных автоматов — но что же является этой 
целью? Наше обобщение автоматов может применяться, 
например, в следующих трёх случаях. 


• Во-первых, это различные точные алгоритмы («пе- 
реборные», brute-force algorithms), описываемые с 
помощью подобных автоматов. Они могут быть при- 
менены в нескольких минимизационных проблемах, 
рассмотренных нами, например в P), 10). См. также 
далее описание алгоритмов для возможности добав- 
ления дуги — это добавление часто даёт возможность 
использовать различные вспомогательные алгорит- 
MBI. 

e Во-вторых, это различные эвристические алгорит- 
мы реального времени — применяемые для тех же 
самых проблем минимизации; см., например, [1], 
121. 

• И, в-третьих, путём использования таких автома- 
тов мы часто упрощаем некоторые доказательства; 
например, некоторые из доказательств, которые мы 
собираемся рассмотреть в части П, могут быть при- 
менены и для обычных НКА. 


Приведём содержание настоящей статьи. В разделе Ц 
приведены некоторые обозначения, введённые в наших 
предыдущих статьях и используемые в настоящей. В 
разделе [ даны основные определения, связанные с 
расширенными конечными автоматами; эти определения 
были впервые введены в (Bh. Также в этом разделе приве- 
дено одно из свойств расширенных автоматов — которое 
фактически определяет их важный частный случай. 

В разделе ГУ мы определяем расширенный конечный 
автомат GE(L) — основной предмет настоящей статьи. В 
разделе [V| мы рассматриваем пример такого автомата и 
на этом примере показываем следующий важный факт: 
существуют регулярные языки, в базисных автоматах ко- 
торых у некоторых вершин нет циклов, соответствующих 


2 В упомянутой работе мы начали рассматривать только одну из этих 
моделей — и предполагаем вернуться к их рассмотрению в последую- 
щих публикациях. 


циклам соответствующих вершин других эквивалентных 
автоматов. 

(Отметим, что термин «соответствующие циклы» при- 
менялся нами в названии статьи 03] — это был основной 
предмет той статьи. А термин «соответствующие верши- 
ны» применялся нами для записей вида 


qE <(А,Х)>к, 


см. подробнее в следующем разделе. Существенно более 
сложная классификация вершин и циклов графа пере- 
ходов недетерминированного конечного автомата была 
приведена нами в — однако для настоящей статьи 
эта классификация вряд ли интересна. Таким образом, 
последнее предложение предыдущего абзаца вполне пра- 
вильное — хотя оно и «не очень красивое».) 

В разделе M] мы показываем адекватность определе- 
ния расширенного базисного конечного автомата — т.е. 
доказываем утверждение о том, что построенный на 
основе исходного языка Г, автомат BE(L) действительно 
определяет этот языкй. А в разделе мы кратко рас- 
сматриваем алгоритмы добавления петли к некоторому 
состоянию автомата BE(L); подробнее эти алгоритмы 
будут рассмотрены в части П настоящей статьи. 


П. ПРЕДВАРИТЕЛЬНЫЕ СВЕДЕНИЯ 


Будем использовать обозначения из наших предыду- 
щих работ, основные из этих обозначений связаны с 
каноническими конечными автоматами. А именно, пусть 
некоторый автомат 


K =(Q,5,6,S,F) (1) 


задаёт регулярный язык Г. Соответствующий канониче- 
ский автомат будем обозначать записью Г.Я Определим 
зеркальный конечный автомат как 


(Q, £, 6?, F, S), 


где условие 
ôP (ат, Ф) Эа 


выполнено тогда и только тогда, когда 


(42,91) э а. 


Будем обозначать автомат, зеркальный 
записью KË. е 

Будем считать, что автоматы L и ГИ для заданного 
регулярного языка Г, таковы: 


= (Q, £, ôn, {5n}, Fr) и LE = (R, E, õp, {8}, Fp). 


к автомату К, 


Записью <L> будем обозначать автомат (LE)E. 
Базисный конечный автомат определяем согласно (Bh. 
[15]. При этом для некоторой пары состояний А Е Q 
и Х Е К мы в наших предыдущих работах для соот- 
ветствующего им состояния базисного автомата употреб- 
ляли два варианта записи: либо on либо (A,X) (при 
этом второй вариант, конечно, может также обозначать 


3 Конечно же, имеется в виду определение регулярного языка не 
на основе классических определений теории конечных автоматов, а на 
основе материала, изложенного в разделе 

4 При этом, как и в наших предыдущих работах, мы не требуем, 
чтобы канонический автомат был всюду определённым (total). Следо- 
вательно, в нём, вообще говоря, нет т.н. «дохлого состояния» (dead 
state). 
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упорядоченную пару состояний). В настоящей статье мы 
будем использовать оба варианта — в зависимости от 
того, какой именно из них более удобен в нужном месте. 

Для автомата K (|), определяющего язык L, и cocto- 
яния (A,X) эквивалентного базисного автомата GA(L) 
будем писать 


<(4,X)>x = [40| 1 (4) э Аи ео (4 эх} 


(об этой записи кратко было упомянуто во введении, в 
тексте про соответствующие вершины). 

Для дальнейшего важными являются следующие два 
утверждения. Они приведены в [16], здесь мы их повто- 
ряем — причём доказательство приведено с небольшими 
дополнениями. 


Утверждение 1: Пусть А – некоторое состояние aB- 
томата Г. Тогда для каждого состояния X автомата LE 
выполнено условие 


L? (A) = Са ((А,Х)). 


Доказательство. Условие 


сво (A,X) © (А) 


очевидно — оно просто является следствием определения 
автомата BA(L). Поэтому мы должны доказать выполне- 
ние включения 


СИ(А) С PAL) (04, Х)); 


докажем это утверждение по индукции. 
Пусть и € С? (А). Базис индукции (т.е. случай и = =) 
очевиден. Докажем шаг индукции, т.е. рассмотрим слу- 
чай |u| > 1. При этом мы можем записать и в виде 
и = va, где a є “uv є &*. Пусть В – состояние 
автомата Г, такое что © Е си (В ). 
Рассмотрим ЕЕ слово w Є У“, такое что 


in 


(т.е. uw = vaw является словом рассматриваемого языка 
Г). Такое слово существует — поскольку автомат L? по 
определению не имеет ни бесполезных, ни недостижи- 
мых состояний. E 
Рассмотрим состояние (пусть У) автомата LE, такое 
что | 
wrae 00) 


Такое состояние существует — иначе слово иш = VAW не 
могло бы входить в заданный язык L. 

Согласно определению бинарного отношения #, вы- 
полнено условие В#У. А по определению автомата 
BA(L) мы получаем, что 


(В, т. Б Х). 
Последний факт доказывает выполнение шага индукции. 
0 


Аналогично доказывается следующий факт. 


Утверждение 2: Пусть L – заданный регулярный язык, 
Пусть X — некоторое состояние автомата Г.И. В Тогда для 
каждого состояния А автомата Г, выполнено условие 


сон (x) = (си (х) = сан, (А.х). 


5 А, следовательно, и автомата <L>. 


Ш. ОПРЕДЕЛЕНИЕ РАСШИРЕННЫХ КОНЕЧНЫХ АВТОМАТОВ 
И СООТВЕТСТВУЮЩИХ РЕГУЛЯРНЫХ ЯЗЫКОВ 


Рассмотрим основные определения, связанные с рас- 
ширенными конечными автоматами. Заранее отметим, 
что для их функций переходов мы будем использовать 
обозначения, определённые ранее для автоматов «обыч- 
ных»; например, для некоторого и E C(q) мы будем 
писать 

u 
ee 


Определение 1: Определим расширенный автомат как 


= (9,5, 6,6, 0", OM), (2) 


где К = (0,%,д,5, Е) - автомат (I), а остальные эле- 
менты являются функциями вида 


ОР 
Кроме того: 
e Ç(q) > = для каждого q Є Q; 


С" (в) э = для каждого s Є 5; 
Cl f) 5 = для каждого Є Е. O 


Определение 2: Пусть 41,42 Е Q - некоторые co- 
стояния расширенного автомата (R); допускаем случай 
qı = 42. Определим язык СЮ (41, 42) следующим обра- 
зом: 


• если и Є [0 (41, qo), то мы считаем, что также 


u € С (41,92); 


• если qı = 42, то (qi) С Сю (91); 
e если для некоторого состояния q Е Q мы уже опре- 
делили, что 


шиє 2 (41,4), vel) и we (4,42), 
то мы полагаем, что wow Є LY? (41, 92); 


• ничто иное не является словом языка L£ (41, 42). O 


Определение 3: Язык расширенного автомата в 
определяется как 


CL(K) = |] a LEa ©" 9. 0 


qEQ 


Очевидно, что не каждый язык, который может быть 
задан согласно определению В} является регулярным — 
просто потому, что множества С, С" и (2 могут быть 
бесконечными. Однако мы будем рассматривать только 
такие случаи, когда эти множества являются регуляр- 
ными языками — из чего следует, например, что язык 
L(K) тоже регулярен. При этом следующее утверждение 
В| описывает некоторые возможные элементы множества 
¢(q), соответствующие реальным автоматам. 

Для функции переходов расширенного автомата будем 
использовать обозначения, ранее введённые для «обыч- 
ных» автоматов; например, для некоторого слова и Е 
¢(q) можно писать 

КГА 
Е 
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Утверждение 3: Пусть для некоторого регулярного 
языка L и определяющего его автомата выполнены 
следующие условия: 


ЧЕ, че <(А,Х)> к, (0) >», 
in (A,X) эч и Кош. ((А,Х)) > w. 


Тогда для каждого i > 0 выполнено условие ‘мо Є Г. В 


Доказательство. Будем в этом доказательстве исполь- 
зовать утверждение ||| без специальных Ha него ссылок. 
Выберем некоторое слово 


ur € (9), 


такое что 
Е LP (A); 


такой выбор возможен в связи с тем, что 
т 
A E€ pkl). 


Для автомата К мы можем записать 


поэтому существует соответствующий путь автомата L 
для некоторого его состояния В. Итак, 


АВ. (3) 
т 
Поскольку 
u € Св (А.Х), 
мы получаем, что 


A. 
L 


A отсюда вследствие 19) выполняется следующий факт: 

АВ. (4) 

Т Т, 
Из условий 
uel (AX), че <(А,Х)>к и vel) 
мы получаем, что 

зк 6) 
Из (И и (5) следует, что 

фк (9) Э В. 
Кроме того, существует слово w, такое что 

WE Lett (A, X)), 


то есть 
w E L(K). 


Отсюда B#X, и, кроме того, uv'we L. O 


Итак, в утверждении В МЫ фактически рассмотрели 
специальный случай расширенного автомата. 


6 Заметим, что, вообще говоря, и ¢ С. (д) иш ¢ L% (а). 


IV. РАСШИРЕННЫЙ БАЗИСНЫЙ КОНЕЧНЫЙ АВТОМАТ: 
ОСНОВНЫЕ ОПРЕДЕЛЕНИЯ 


Всюду в этом разделе считаем регулярный язык L 
заданным. Для него определим расширенный конечный 
автомат BE(L), элементы которого задаются согласно 
следующему определению. 


Определение 4: Пусть (A, Х) — некоторое состояние 
автомата BA(L) для заданного регулярного языка Г. 
Определим функции 


следующим образом. 


• Пусть — некоторый конечный автомат, определя- 
ющий Г, а д E Q – некоторое его состояние, такое 
что q E < (А, X)> к. Пусть также 


и Є ee (q). 
Тогда будем считать, что 


u E€ Cæ) ((4, Х)). 


Ничто иное словом языка 


Све(р)((А, X)) 


не является. 

e Пусть — некоторый конечный автомат, определя- 
ющий язык Г, Па q О – некоторое его состояние, 
такое что 


qE <(4,X)> x. 
Пусть также 
u € С" (а). 
Тогда будем считать, что 


u € (р) ((A,X)). 


Ничто иное словом языка 


С) ((A, Х)) 


не является. 

• Пусть — некоторый конечный автомат, определя- 
ющий L, aq Є Q – некоторое его состояние, такое 
что 


А x. 


Пусть также 
ue LE (0). 


Тогда будем считать, что 


ие (А, Х)). 


Ничто иное словом множества 
(А, Х)) 


7 Важно отметить, что, вообще говоря, этот автомат отличается от 
рассматривавшегося в предыдущем пункте определения. То же — для 
следующего пункта. Ещё раз отметим, что в каждом из этих пунктов 
выбирается какой-нибудь произвольный автомат для языка L, причём 
для разных слов U, рассматриваемых в каждом из этих пунктов, авто- 
маты могут быть различными. Иными словами — мы рассматриваем 
все возможные варианты автоматов и соответствующих слов. 
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не является. В 
Расширенный конечный автомат BE(L) определяется как 


BE(L) = (T(L), >, дв, Св), С, ou ): 


BE(L) 


V. ПРИМЕР 


В качестве примера рассмотрим пример языка Г, 3a- 
данного регулярным выражением 


(a + ab + ba)*. (6) 


Соответствующий базисный автомат изображён на рис. 1. 


Рис. 1. Базисный автомат для языка, определяемого РВ @ 


В (8) мы отмечали, что каждый ИЗ ЯЗЫКОВ 
out 


Cee(n)((B,Y)), Cay (BY) и С ((B,Y)) 


соответствующих состоянию (В, У) базисного автомата, 
содержит слово ab — несмотря на то, что этого слова не 
содержит ни один из аналогичных языков 


Ln (В,У)), Lia (В,У)) и С ((В,Ү)) 


(для того же самого состояния базисного автомата 
(В, У), рис. 1). Для первого из упомянутых языков, т.е. 
Све(г)((В,У)), это можно показать, например, следую- 
щим образом: 

e состояние 4: соответствующего этому языку авто- 
мата, приведённого на рис. 2, содержит цикл, име- 
ющий пометку ab; 

e мы показывали в 7 и других статьях, что для 
рассматриваемого языка выполнено следующее: 


т out А 
Фк(@) эВ и фк (Ф) ЭҮ; 
8 Условия двух последних пунктов можно переписать в виде 
ek) ЭА и pk) Э Х 


соответственно. 


• к последним двум фактам применяем определение Д 


Рис. 2. Автомат для языка, определяемого РВ (a) 


Таким образом, «всё He так просто»: на этом примере 
мы показываем, что существуют регулярные языки, в 
базисных автоматах которых у некоторых вершин нет 
циклов, соответствующих циклам соответствующих вер- 
шин других эквивалентных автоматовй. Ho, несмотря 
на это, выполняется важная теорема | приведённая в 
следующем разделе; она фактически показывает адекват- 
ность определения расширенного базисного конечного 
автомата — т.е. тот факт, что построенный на основе 
исходного языка L автомат В (Г) действительно опре- 
деляет этот язык. А в качестве некоторого дополнения к 
теореме ||] можно рассматривать материал раздела K 
этим вопросам мы вернёмся в части П настоящей статьи. 


VI. РАСШИРЕННЫЙ БАЗИСНЫЙ КОНЕЧНЫЙ АВТОМАТ: 
АДЕКВАТНОСТЬ ОПРЕДЕЛЕНИЯ 


Докажем основное утверждение этого раздела. 
Теорема 1: L(BE(L)) = Г. 
Достаточно доказать, что 


L(BE(L)) CL 


Доказательство. 


(обратное утверждение очевидно). 

Рассмотрим некоторое слово w є С(В$ (Г). Поскольку 
w получено согласно определениям В] и Д мы можем 
записать его в виде 


w = мо (1) ил (5) из... шат (оп) Uns 

где: 
e Ее bee (ry (4, 
Е б) для состояния 


)иї; > 0 для каждого j Є {1,...,n}; 


1 
= Є T(L), 


соответствующего слову 11; отсюда согласно опре- 
делению Д мы можем выбрать состояние 


т, 


такое что 
АО чо Al 
xo aX” 


где А? = 8, — стартовое состояние автомата L; 


e аналогично, 
Ап un Anti 
Xn BA(L) Xn41> 


9 Замечание о «не очень красивой» терминологии было приведено 
во введении. 
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где Х”+! = s, — стартовое состояние автомата ГИ; 
• следовательно, и0и1и2...ии — слово, являющееся 
пометкой пути автомата BA(L), то есть 
Ao vo, Al Gey А2 мау N 
0 1 2 ... 
X? BAL) Х BAE) Х ва) BACE) X” BAC 


для некоторых CO стояний 


дО А1 A2 A” Anti 
ХО? X1? X2% Хп Хит € T(L). 


Заметим, что для каждого возможного ј мы допускаем 
случай uj = Е. 
Определим 
жк = чо (1) ит (92)? U2... Uk—-1(Vk) E Uk, 


/ 
Tk = ЧОЦ]... Uk, И Yk = Uk4+1---Un- 


Докажем по индукции по КЕ 0,1,...,п, что: 

• TkYk E L; 

• для (единственного) пути автомата GA(L) вида 
Ze, p Ры 
BA(L) BA(L) 

выполнено следующее условие: 
вк+1 

t= Xk+15 


заметим, что мы используем заранее зафиксирован- 
ное состояние X*+! автомата LE, а также некоторое 
состояние В®+! автомата Г. 4 
Базис индукции (т.е. случай К = 0) очевиден — при 
этом мы рассматриваем как слово автомата BA(L), а 
не GE(L); таким образом, 


t1 =t 
Докажем шаг индукции. 
Рассмотрим слово 


Wy = т (+1) "t Yk- 


Согласно утверждению В} wi, Е ime Кроме того, вслед- 
ствие (P), хук € Г. Также на основе (M) мы получаем, 
что 


(ук) 


KEL 
LR 
поэтому 
a’ АКТ (vp41) k+: kEi 
оон ee а 25 (8) 
BA(L) BA(L) BA(L) 


для некоторого состояния C*+! автомата 7.13 
По предположению индукции и (8) мы для некоторого 
состояния D*+! автомата L получаем следующий путь 


Tk Bk+l (vki) Ft рем Yk 
BL) Х“ BĮ)  *"** parr) И) 


10 Отметим, что возможен случай ВЕІ = АЕ+1, 

И Процесс доказательства по индукции мы иллюстрируем рисунком 
3, на котором приведена работа автомата ВА(Г,). Некоторые коммента- 
рии к рисунку будут приведены далее — также в сносках. 

12 Путь автомата ВА(Г,), принимающий это слово, отмечен на pH- 
сунке малыми кружками, каждый из которых имеет номер 1. Отметим 
также, что автомат BA(L) является однозначным — поэтому выражение 
путь (а не «один из путей») верное. 

13 Для одного из последних шагов индукции, а именно для k + 1 = 
n — 1, те. k = п- 2, состояние C*+! отмечено знаком вопроса — 
внутри состояния базисного автомата, помеченного малым кружком с 
номером 2. Знак вопроса при этом используется потому, что таким 
же образом может быть отмечено и состояние рк+1, которое будет 
введено в следующем абзаце. 


Dha 


a-l 


Oju 


Рис. 3. Иллюстрация к доказательству теоремы 


Кроме TOTO, ДЛЯ k < п мы можем записать в в виде 


(vk+1) RHI 


BA(L) 


zk, ВА 
k+1 
BA(L) Х 


РЕ! 
Xk+1 


Bret? 
Xk+2 


Uk+1 


BA(L) 


Ук+1 


. (10 
т A 


Состояние X**? было зафиксировано ранее, поэтому 
состояние B+? может быть выбрано на основе (10). 
А существование требуемого состояния B+? доказывает 
шаг индукции для К < п. 

Итак, мы доказали, что ш = 
получаем, что L(BE(L))=L. 0 


InYn Є L; отсюда 


УП. ОБ АЛГОРИТМАХ ДОБАВЛЕНИЯ ПЕТЛИ 
И О ЧАСТИ П НАСТОЯЩЕЙ СТАТЬИ 


Как мы уже отмечали во введении, алгоритмы, которые 
могут быть созданы на основе описанных в настоящем 
разделе утверждений, на первый взгляд вряд ли могут 
быть названы «алгоритмами упрощения» автомата. Од- 
нако во многих задачах преобразования конечных авто- 
матов эти алгоритмы могут быть вспомогательными «для 
временного небольшого ухудшения структуры автомата 
с целью её существенного последующего улучшения» — 
т.е. для последующего удаления некоторых состояний 
автомата и/или его дуг; таким образом, эти алгоритмы 


14 Процесс выбора состояния BFT? — сначала неизвестного, поэтому 
также первоначально обозначенному заком вопроса, — помечен на 
рисунке малым кружком с номером 3. 
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действительно могут являться вспомогательными алго- 
ритмами для минимизационных проблем. Например, ал- 
горитмы, сформулированные в [18] для описания мно- 
жества возможных дуг, являются существенно более 
быстрыми, чем простейшие переборные алгоритмы, 
— однако BCé же вряд ли могут быть использованы на 
практике. Поэтому, рассматривая конкретный конечный 
автомат, мы можем «постараться» описать множество 
«недостающих в нём» возможных дуг! 

Утверждение 4: Пусть 4 – некоторое состояние авто- 
мата В (Г), причём 


Тогда и Є Све (1)(9). 0 

Мы не будем строго доказывать это утверждение — 
а именно, мы не будем доказывать, что существует ав- 
томат вида (|1), для которого требуемое слово и может 
быть выбрано на основе определения И мы приведём 
такое доказательство в части II, в нём мы определим 
необходимые элементы автомата (ÎI). Кроме того, следу- 
ющим обстоятельство может даже являться аргументом, 
что подобное доказательство малоинтересно. Если мы 
просто добавим слово и в язык Свє(џ) (те. если мы 
таким образом дополним определение В, то очевидно, 
что мы получим автомат, эквивалентный заданному; этот 
факт можно рассматривать как следствие определения 
Например, для регулярного выражения (6) на основе 
показанного выше факта 


Све(к)((В,У)) > ab 


и отмеченного выше мы можем утверждать, что к состо- 
янию (В,У) автомата GA(L) можно добавить цикл с 
пометкой ab. 
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Extended basis finite automaton. 
Part I. The basic definitions 


Boris Melnikov, Aleksandra Melnikova 


Abstract—In this paper, we consider a special extension of 
the class of non-deterministic finite automata. The purpose 
of this consideration is the following: first, to describe using 
such automata various brute-force algorithms of equivalent 
transformation of automata; secondly, the application of the 
described extension in several minimization problems for 
ordinary non-deterministic finite automata; thirdly, with the 
help of these automata we can simplify some proofs, which are 
also necessary for ordinary finite automata. 

In the paper, we consider the definition of extended finite 
automata, give examples, define the extended basic finite 
automaton for the given regular language and consider some 
properties of this automaton. We also prove, that for the 
extended basis automaton all the auxiliary languages obtained 
in the constructions are regular. All this allows to simplify the 
definition of an extended basic automaton. 

We also show the adequacy of the definition of an extended 
basis finite automaton, i.e. we prove the assertion that the 
extended basic automaton constructed on the basis of the source 
regular language really defines this language. And on one of 
the examples we show the following fact: there are regular 
languages, in whose basic automata some vertices do not have 
cycles corresponding to the cycles of the corresponding vertices 
of other equivalent automata; such cycles exist in similar 
vertices of extended basic automata. 


Keywords—Regular languages, nondeterministic finite 
automata, the extension of automata, algorithms of equivalent 
transformation for automata. 
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